// 进行axios二次封装,使用请求与响应拦截器
import axios from "axios";
import { ElMessage } from "element-plus";
// 引入用户相关的仓库
import useUserStore from "@/store/modules/user";

// 第一步:利用axios对象的create方法创建一个axios实例(其他配置:基础路径,超时时间)
const request = axios.create({
  // 基础路径
  baseURL: import.meta.env.VITE_APP_BASE_API, // 基础路径上会携带/api
  timeout: 5000, // 超时时间的设置
});

// 第二步:request实例添加请求与响应拦截器
request.interceptors.request.use((config) => {
  // 获取用户相关小仓库,拿到token
  const userStore = useUserStore();
  if (userStore.token) {
    // 如果用户仓库有token,请求头携带token
    config.headers.token = userStore.token;
  }
  // config配置对象,headers属性请求头,经常给服务器端携带公共参数
  // 返回配置对象
  return config;
});

// 第三步:响应拦截器
request.interceptors.response.use(
  // 成功的回调
  (response) => {
    // 简化数据
    return response.data;
  },
  (error) => {
    // 失败的回调:处理http网络错误
    // 定义一个变量,存储网络错误信息
    let message = "";
    // http状态码
    const status = error.response?.status;
    if (status) {
      switch (status) {
        case 401:
          message = "token过期";
          break;
        case 403:
          message = "无权访问";
          break;
        case 404:
          message = "请求地址出现错误";
          break;
        case 500:
          message = "服务器出现问题";
          break;
        default:
          message = "网络异常";
      }

      // 提示错误信息
      ElMessage({
        type: "error",
        message,
      });
    } else {
      ElMessage({
        type: "error",
        message: "网络异常",
      });
    }

    return Promise.reject(error);
  }
);

// 对外暴露
export default request;
